<template>
  <div>
    <span class="ant-pro-account-avatar">
      <span
        >{{ company.company.company.companyName }}-{{
          company.company.sysDept.deptName
        }}({{ name }})</span
      >
    </span>
    <a-dropdown placement="bottomRight">
      <span class="ant-pro-account-avatar">
        <!-- <span
          >{{ company.company.company.companyName }}-{{
            company.company.sysDept.deptName
          }}({{name}})</span
        > -->
        <a-avatar
          size="small"
          :src="avatar"
          class="antd-pro-global-header-index-avatar"
        />
      </span>
      <template v-slot:overlay>
        <a-menu class="ant-pro-drop-down menu" :selected-keys="[]">
          <!-- <a-menu-item v-if="menu" key="center" @click="handleToCenter">
          <a-icon type="user" />
          个人中心
        </a-menu-item> -->
          <a-menu-item v-if="menu" key="settings" @click="handleToSettings">
            <a-icon type="setting" />
            个人中心
          </a-menu-item>
          <a-menu-divider v-if="menu" />
          <a-menu-item key="logout" @click="handleLogout">
            <a-icon type="logout" />
            退出登录
          </a-menu-item>
        </a-menu>
      </template>
    </a-dropdown>
  </div>
</template>

<script>
import { Modal } from "ant-design-vue";
import { mapGetters } from "vuex";

export default {
  name: "AvatarDropdown",
  props: {
    menu: {
      type: Boolean,
      default: true,
    },
  },
  computed: {
    ...mapGetters(["avatar", "name", "company"]),
  },
  methods: {
    handleToCenter() {
      this.$router.push({ path: "/account/center" });
    },
    handleToSettings() {
      this.$router.push({ path: "/account/settings" });
    },
    handleLogout(e) {
      Modal.confirm({
        title: "提示",
        content: "确定注销并退出系统吗？",
        onOk: () => {
          // return new Promise((resolve, reject) => {
          //   setTimeout(Math.random() > 0.5 ? resolve : reject, 1500)
          // }).catch(() => console.log('Oops errors!'))
          return this.$store.dispatch("Logout").then(() => {
            this.$router.push({ name: "login" });
          });
        },
        onCancel() {},
      });
    },
  },
};
</script>

<style lang="less" scoped>
.ant-pro-drop-down {
  /deep/ .action {
    margin-right: 8px;
  }
  /deep/ .ant-dropdown-menu-item {
    min-width: 160px;
  }
}
</style>
